<template>
    <view>
        <view v-if="showHeader" class="van-cascader__header">
            <text class="van-cascader__title">
                <slot name="title"></slot>
                {{ title }}
            </text>
            <van-icon v-if="closeable" :name="closeIcon" class="van-cascader__close-icon" @tap.native="onClose" />
        </view>

        <van-tabs
            :active="activeTab"
            custom-class="van-cascader__tabs"
            wrap-class="van-cascader__tabs-wrap"
            tab-class="van-cascader__tab"
            :color="activeColor"
            :border="false"
            :swipeable="swipeable"
            @click="onClickTab"
        >
            <van-tab
                :title="tab.selected ? tab.selected[textKey] : placeholder"
                style="width: 100%"
                :title-style="!tab.selected ? 'color: #969799;font-weight:normal;' : ''"
                v-for="(tab, tabIndex) in tabs"
                :key="tabIndex"
            >
                <!-- 暂不支持 -->

                <!-- <slot name="options-top"></slot> -->

                <view class="van-cascader__options">
                    <view
                        :class="option.className + ' ' + utils.optionClass(tab, valueKey, option)"
                        :style="utils.optionStyle({ tab, valueKey, option, activeColor })"
                        :data-option="option"
                        :data-tab-index="tabIndex"
                        @tap="onSelect"
                        v-for="(option, index) in tab.options"
                        :key="index"
                    >
                        <text>{{ option[textKey] }}</text>

                        <van-icon v-if="utils.isSelected(tab, valueKey, option)" name="success" size="18" />
                    </view>
                </view>

                <!-- 暂不支持 -->

                <!-- <slot name="options-bottom"></slot> -->
            </van-tab>
        </van-tabs>
    </view>
</template>
<script module="utils" lang="wxs" src="@/miniprogram_npm/@vant/weapp/cascader/index.wxs"></script>
<script>
'use strict';
var __spreadArray =
    (this && this.__spreadArray) ||
    function (to, from, pack) {
        if (pack || arguments.length === 2) {
            for (var i = 0, l = from.length, ar; i < l; i++) {
                if (ar || !(i in from)) {
                    if (!ar) {
                        ar = Array.prototype.slice.call(from, 0, i);
                    }
                    ar[i] = from[i];
                }
            }
        }
        return to.concat(ar || Array.prototype.slice.call(from));
    };
Object.defineProperty(exports, '__esModule', {
    value: true
});
var component_1 = require('../common/component');
var FieldName;
(function (FieldName) {
    FieldName['TEXT'] = 'text';
    FieldName['VALUE'] = 'value';
    FieldName['CHILDREN'] = 'children';
})(FieldName || (FieldName = {}));
var defaultFieldNames = {
    text: FieldName.TEXT,
    value: FieldName.VALUE,
    children: FieldName.CHILDREN
};
export default {
    data() {
        return {
            tabs: [],
            activeTab: 0,
            textKey: FieldName.TEXT,
            valueKey: FieldName.VALUE,
            childrenKey: FieldName.CHILDREN,
            innerValue: '',

            tab: {
                selected: false,
                options: []
            },

            tabIndex: 0,

            option: {
                className: ''
            }
        };
    },
    props: {
        title: String,
        value: {
            type: String
        },
        placeholder: {
            type: String,
            default: '请选择'
        },
        activeColor: {
            type: String,
            default: '#1989fa'
        },
        options: {
            type: Array,
            default: () => []
        },
        swipeable: {
            type: Boolean,
            default: false
        },
        closeable: {
            type: Boolean,
            default: true
        },
        showHeader: {
            type: Boolean,
            default: true
        },
        closeIcon: {
            type: String,
            default: 'cross'
        },
        fieldNames: {
            type: Object,
            default: defaultFieldNames
        }
    },
    watch: {
        options: function () {
            this.updateTabs();
        },

        value: function (newVal) {
            this.updateValue(newVal);
        },

        fieldNames: {
            handler: function () {
                var _a = this.fieldNames || defaultFieldNames;
                var _b = _a.text;
                var text = _b === void 0 ? 'text' : _b;
                var _c = _a.value;
                var value = _c === void 0 ? 'value' : _c;
                var _d = _a.children;
                var children = _d === void 0 ? 'children' : _d;
                this.setData({
                    textKey: text,
                    valueKey: value,
                    childrenKey: children
                });
            },

            immediate: true,
            deep: true
        }
    },
    created: function () {
        this.updateTabs();
    },
    methods: {
        updateValue: function (val) {
            var that = this;
            if (val !== undefined) {
                var values = this.tabs.map(function (tab) {
                    return tab.selected && tab.selected[that.valueKey];
                });
                if (values.indexOf(val) > -1) {
                    return;
                }
            }
            this.innerValue = val;
            this.updateTabs();
        },
        updateFieldNames: function () {
            var _a = this.fieldNames || defaultFieldNames;
            var _b = _a.text;
            var text = _b === void 0 ? 'text' : _b;
            var _c = _a.value;
            var value = _c === void 0 ? 'value' : _c;
            var _d = _a.children;
            var children = _d === void 0 ? 'children' : _d;
            this.setData({
                textKey: text,
                valueKey: value,
                childrenKey: children
            });
        },
        getSelectedOptionsByValue: function (options, value) {
            for (var i = 0; i < options.length; i++) {
                var option = options[i];
                if (option[this.valueKey] === value) {
                    return [option];
                }
                if (option[this.childrenKey]) {
                    var selectedOptions = this.getSelectedOptionsByValue(option[this.childrenKey], value);
                    if (selectedOptions) {
                        return __spreadArray([option], selectedOptions, true);
                    }
                }
            }
        },
        updateTabs: function () {
            var that = this;
            var options = this.options;
            var innerValue = this.innerValue;
            if (!options.length) {
                return;
            }
            if (innerValue !== undefined) {
                var selectedOptions = this.getSelectedOptionsByValue(options, innerValue);
                if (selectedOptions) {
                    var optionsCursor_1 = options;
                    var tabs_1 = selectedOptions.map(function (option) {
                        var tab = {
                            options: optionsCursor_1,
                            selected: option
                        };
                        var next = optionsCursor_1.find(function (item) {
                            return item[that.valueKey] === option[that.valueKey];
                        });
                        if (next) {
                            optionsCursor_1 = next[that.childrenKey];
                        }
                        return tab;
                    });
                    if (optionsCursor_1) {
                        tabs_1.push({
                            options: optionsCursor_1,
                            selected: null
                        });
                    }
                    this.setData({
                        tabs: tabs_1
                    });
                    this.$nextTick(function () {
                        that.setData({
                            activeTab: tabs_1.length - 1
                        });
                    });
                    return;
                }
            }
            this.setData({
                tabs: [
                    {
                        options: options,
                        selected: null
                    }
                ]
            });
        },
        onClose: function () {
            this.$emit('close');
        },
        onClickTab: function (e) {
            var _a = e.detail;
            var tabIndex = _a.index;
            var title = _a.title;
            this.$emit('click-tab', {
                title: title,
                tabIndex: tabIndex
            });
            this.setData({
                activeTab: tabIndex
            });
        },
        // 选中
        onSelect: function (e) {
            var that = this;
            var _a = e.currentTarget.dataset;
            var option = _a.option;
            var tabIndex = _a.tabIndex;
            if (option && option.disabled) {
                return;
            }
            var _b = this;
            var valueKey = _b.valueKey;
            var childrenKey = _b.childrenKey;
            var tabs = this.tabs;
            tabs[tabIndex].selected = option;
            if (tabs.length > tabIndex + 1) {
                tabs = tabs.slice(0, tabIndex + 1);
            }
            if (option[childrenKey]) {
                var nextTab = {
                    options: option[childrenKey],
                    selected: null
                };
                if (tabs[tabIndex + 1]) {
                    tabs[tabIndex + 1] = nextTab;
                } else {
                    tabs.push(nextTab);
                }
                this.$nextTick(function () {
                    that.setData({
                        activeTab: tabIndex + 1
                    });
                });
            }
            this.setData({
                tabs: tabs
            });
            var selectedOptions = tabs
                .map(function (tab) {
                    return tab.selected;
                })
                .filter(Boolean);
            var value = option[valueKey];
            var params = {
                value: value,
                tabIndex: tabIndex,
                selectedOptions: selectedOptions
            };
            this.innerValue = value;
            this.$emit('change', params);
            if (!option[childrenKey]) {
                this.$emit('finish', params);
            }
        }
    }
};
</script>
<style>
@import './index.css';
</style>
